/**
 * Licensed to Apereo under one or more contributor license agreements. See the NOTICE file
 * distributed with this work for additional information regarding copyright ownership. Apereo
 * licenses this file to you under the Apache License, Version 2.0 (the "License"); you may not use
 * this file except in compliance with the License. You may obtain a copy of the License at the
 * following location:
 *
 * <p>http://www.apache.org/licenses/LICENSE-2.0
 *
 * <p>Unless required by applicable law or agreed to in writing, software distributed under the
 * License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
 * express or implied. See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.apereo.portal.portlet.rendering.worker;

/** @param <V> */
public interface IPortletExecutionWorker<V> extends IPortletExecutionContext {

    /**
     * Submit the worker for execution. The worker may start immediately or submit itself to a
     * thread pool or service for execution at a future time.
     *
     * <p>Submit should only be called ONCE
     */
    public void submit();

    /**
     * Wait for the worker to start.
     *
     * @param timeout The maximum time in ms to wait for the worker to start
     * @return The time in ms that the worker actually started, 0 if it has not started
     */
    public long waitForStart(long timeout) throws InterruptedException;

    /**
     * Get the object returned by the worker's execution
     *
     * @param timeout The maximum time in ms to wait for the worker to complete, if the worker has
     *     not started yet this includes time spent waiting to start
     * @return The object returned by the portlet execution
     * @throws Exception The exception thrown by the portlet during execution if any
     */
    public V get(long timeout) throws Exception;

    /** Cancel the worker, interrupting the thread that is executing the worker */
    public void cancel();

    /** @return The number of times that cancel has been called. */
    public int getCancelCount();

    /** @return true If {@link #get(long)} has been called */
    public boolean isRetrieved();
}
